home *** CD-ROM | disk | FTP | other *** search
/ SGI Freeware 1999 August / SGI Freeware 1999 August.iso / dist / fw_xemacs.idb / usr / freeware / lib / xemacs-20.4 / lisp / prim / keydefs.el.z / keydefs.el
Encoding:
Text File  |  1998-05-21  |  23.9 KB  |  623 lines

  1. ;; Define standard keybindings.
  2. ;; Copyright (C) 1992, 1993, 1994 Free Software Foundation, Inc.
  3.  
  4. ;; This file is part of XEmacs.
  5.  
  6. ;; XEmacs is free software; you can redistribute it and/or modify it
  7. ;; under the terms of the GNU General Public License as published by
  8. ;; the Free Software Foundation; either version 2, or (at your option)
  9. ;; any later version.
  10.  
  11. ;; XEmacs is distributed in the hope that it will be useful, but
  12. ;; WITHOUT ANY WARRANTY; without even the implied warranty of
  13. ;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
  14. ;; General Public License for more details.
  15.  
  16. ;; You should have received a copy of the GNU General Public License
  17. ;; along with XEmacs; see the file COPYING.  If not, write to the 
  18. ;; Free Software Foundation, 59 Temple Place - Suite 330,
  19. ;; Boston, MA 02111-1307, USA.
  20.  
  21. ;; All the global bindings should be here so that one can reload things
  22. ;; like files.el without trashing one's personal bindings.
  23.  
  24. ;;; Synched up with: Not synched with FSF.
  25.  
  26. ;;; Commentary:
  27.  
  28. ;;; Code:
  29.  
  30. ;; created by C code
  31. (defvar global-map (current-global-map) "\
  32. Default global keymap mapping XEmacs keyboard input into commands.
  33. The value is a keymap which is usually (but not necessarily) XEmacs's
  34. global map.")
  35.  
  36. ;; created by C code
  37. (defvar esc-map (symbol-function 'ESC-prefix) "\
  38. Default keymap for ESC (meta) commands.
  39. The normal global definition of the character ESC indirects to this keymap.")
  40.  
  41. (set-keymap-name global-map 'global-map)
  42. (set-keymap-name esc-map 'ESC-prefix)
  43.  
  44. (define-prefix-command 'Control-X-prefix t)
  45. (defvar ctl-x-map (symbol-function 'Control-X-prefix) "\
  46. Default keymap for C-x commands.
  47. The normal global definition of the character C-x indirects to this keymap.")
  48. (define-key global-map "\C-x" 'Control-X-prefix)
  49.  
  50. (define-prefix-command 'ctl-x-4-prefix t)
  51. (defvar ctl-x-4-map (symbol-function 'ctl-x-4-prefix) "\
  52. Keymap for subcommands of C-x 4")
  53. (define-key global-map "\C-x4" 'ctl-x-4-prefix)
  54.  
  55. (define-prefix-command 'ctl-x-5-prefix t)
  56. (defvar ctl-x-5-map (symbol-function 'ctl-x-5-prefix) "\
  57. Keymap for subcommands of C-x 5")
  58. (define-key global-map "\C-x5" 'ctl-x-5-prefix)
  59.  
  60. (define-prefix-command 'mode-specific-command-prefix t)
  61. (defvar mode-specific-map (symbol-function 'mode-specific-command-prefix) "\
  62. Keymap for characters following C-c.")
  63. (define-key global-map "\C-c" 'mode-specific-command-prefix)
  64.  
  65. ;; FSFmacs buffer.c
  66.  
  67. (define-key global-map "\C-xb" 'switch-to-buffer)
  68. (define-key global-map "\C-xk" 'kill-buffer)
  69. (define-key global-map "\C-x\C-b" 'list-buffers)
  70. (put 'erase-buffer 'disabled t)         ;from buffer.c
  71.  
  72. ;; FSFmacs casefiddle.c
  73.  
  74. (define-key global-map "\C-x\C-u" 'upcase-region)
  75. ;; This is silly with zmacs regions
  76. ;(put 'upcase-region 'disabled t)
  77. (define-key global-map "\C-x\C-l" 'downcase-region)
  78. ;; This is silly with zmacs regions
  79. ;(put 'downcase-region 'disabled t)
  80. (define-key global-map "\M-u" 'upcase-region-or-word)
  81. (define-key global-map "\M-l" 'downcase-region-or-word)
  82. (define-key global-map "\M-c" 'capitalize-region-or-word)
  83.  
  84. ;; FSFmacs cmds.c
  85.  
  86. (let ((n 33))
  87.   (while (<= n 255)
  88.     (if (not (= n 127))
  89.         (define-key global-map n 'self-insert-command))
  90.     (setq n (1+ n))))
  91. (define-key global-map " " 'self-insert-command)
  92.  
  93. (define-key global-map "\C-a" 'beginning-of-line)
  94. (define-key global-map "\C-b" 'backward-char)
  95. (define-key global-map "\C-e" 'end-of-line)
  96. (define-key global-map "\C-f" 'forward-char)
  97. (define-key global-map "\C-d" 'delete-char)
  98. (define-key global-map 'delete 'backward-or-forward-delete-char)
  99. (define-key global-map '(meta delete) 'backward-or-forward-kill-word)
  100. (define-key global-map [(control x) (delete)] 'backward-or-forward-kill-sentence)
  101.  
  102. ;; FSFmacs files.el
  103.  
  104. (define-key global-map "\C-x\C-f" 'find-file)
  105. (define-key global-map "\C-x\C-q" 'toggle-read-only)
  106. (define-key global-map "\C-x\C-r" 'find-file-read-only)
  107. (define-key global-map "\C-x\C-v" 'find-alternate-file)
  108. (define-key global-map "\C-x\C-s" 'save-buffer)
  109. (define-key global-map "\C-xs" 'save-some-buffers)
  110. (define-key global-map "\C-x\C-w" 'write-file)
  111. (define-key global-map "\C-xi" 'insert-file)
  112. (define-key global-map "\M-~" 'not-modified)
  113. (define-key global-map "\C-x\C-d" 'list-directory)
  114. (define-key global-map "\C-x\C-c" 'save-buffers-kill-emacs)
  115.  
  116. (define-key global-map "\C-x4f" 'find-file-other-window)
  117. (define-key global-map "\C-x4r" 'find-file-read-only-other-window)
  118. (define-key global-map "\C-x4\C-f" 'find-file-other-window)
  119. (define-key global-map "\C-x4b" 'switch-to-buffer-other-window)
  120. (define-key global-map "\C-x4\C-o" 'display-buffer)
  121.  
  122. (define-key global-map "\C-x5b" 'switch-to-buffer-other-frame)
  123. (define-key global-map "\C-x5f" 'find-file-other-frame)
  124. (define-key global-map "\C-x5\C-f" 'find-file-other-frame)
  125. (define-key global-map "\C-x5r" 'find-file-read-only-other-frame)
  126.  
  127. ;; FSFmacs frame.c
  128. ;FSFmacs has these.  It's probably a good idea to provide ways of hooking
  129. ;these events, but it's unlikely that it's a good idea to do it this way.
  130. ;Just provide a hook, like the existing `select-frame-hook',
  131. ;`deselect-frame-hook', `map-frame-hook', and `unmap-frame-hook'.
  132. ;#### ergo need hooks for delete-frame and iconify-frame
  133. ;(define-key global-map 'switch-frame 'handle-switch-frame)
  134. ;(define-key global-map 'delete-frame 'handle-delete-frame)
  135. ;(define-key global-map 'iconify-frame 'ignore-event)
  136. ;(define-key global-map 'make-frame-visible 'ignore-event)
  137.  
  138. ;; FSFmacs frame.el
  139.  
  140. ;; New FSF19 bindings: C-x 5 as prefix for window commands
  141. (define-key global-map "\C-x52" 'make-frame)
  142. (define-key global-map "\C-x50" 'delete-frame)
  143. (define-key global-map "\C-x5o" 'other-frame)
  144.  
  145. ;; FSFmacs help.el
  146.  
  147. (define-key global-map (vector help-char) 'help-command)
  148. (define-key global-map 'help 'help-command)
  149. (define-key global-map 'f1 'help-command)
  150.  
  151. ;; FSFmacs indent.el
  152.  
  153. ;;(define-key global-map "\t" 'self-insert-command)
  154. (define-key global-map "\t" 'indent-for-tab-command)
  155. (define-key global-map "\M-\C-\\" 'indent-region)
  156. (define-key global-map "\C-x\t" 'indent-rigidly)
  157. (define-key global-map "\M-i" 'tab-to-tab-stop)
  158. ;; XEmacs addition:
  159. (define-key global-map [(shift tab)] 'tab-to-tab-stop)
  160.  
  161. ;; FSFmacs isearch.el
  162.  
  163. (define-key global-map "\C-s" 'isearch-forward)
  164. (define-key global-map "\C-r" 'isearch-backward)
  165. (define-key global-map "\M-\C-s" 'isearch-forward-regexp)
  166. (define-key global-map "\M-\C-r" 'isearch-backward-regexp)
  167.  
  168. ;; FSFmacs keyboard.c
  169.  
  170. (define-key global-map "\C-z" 'suspend-emacs-or-iconify-frame)
  171. (define-key global-map "\C-x\C-z" 'suspend-or-iconify-emacs)
  172.  
  173. ;; FSFmacs loaddefs.el
  174.  
  175. ;; New FSF19 bindings: C-x n as a prefix for narrowing commands.
  176. (define-key global-map "\C-xn" (let ((map (make-sparse-keymap)))
  177.                                  (set-keymap-name map 'narrowing-prefix)
  178.                                  map))
  179. (put 'narrow-to-region 'disabled t)
  180. (define-key global-map "\C-xnn" 'narrow-to-region)
  181. (define-key global-map "\C-xnw" 'widen)
  182. (define-key global-map "\C-xnd" 'narrow-to-defun)
  183. ;; Old v18 bindings
  184. ;(define-key global-map "\C-xn" 'narrow-to-region)
  185. ;(define-key global-map "\C-xw" 'widen)
  186.  
  187. (define-key global-map "\C-j" 'newline-and-indent)
  188. (define-key global-map "\C-m" 'newline)
  189. (define-key global-map "\C-o" 'open-line)
  190. (define-key global-map "\M-\C-o" 'split-line)
  191. (define-key global-map "\C-q" 'quoted-insert)
  192. (define-key global-map "\M-^" 'delete-indentation)
  193. (define-key global-map "\M-\\" 'delete-horizontal-space)
  194. (define-key global-map "\M-m" 'back-to-indentation)
  195. (define-key global-map "\C-x\C-o" 'delete-blank-lines)
  196. (define-key global-map "\M- " 'just-one-space)
  197. (define-key global-map "\M-z" 'zap-to-char)
  198. (define-key global-map "\M-=" 'count-lines-region)
  199. (define-key global-map "\C-x=" 'what-cursor-position)
  200. (define-key global-map "\M-:" 'eval-expression)
  201. ;; Define ESC ESC : like ESC : for people who type ESC ESC out of habit.
  202. (define-key global-map "\M-\e:" 'eval-expression)
  203. ;(define-key global-map "\M-\e" 'eval-expression)
  204. ;; Do we really need to disable this now that it is harder to type
  205. ;; by accident?
  206. ;; (put 'eval-expression 'disabled t)
  207. ;; Changed from C-x ESC so that function keys work following C-x.
  208. (define-key global-map "\C-x\e\e" 'repeat-complex-command)
  209. ;(define-key global-map "\C-x\e" 'repeat-complex-command)
  210. (define-key global-map "\C-xu" 'advertised-undo)
  211. ;; Many people are used to typing C-/ on X terminals and getting C-_.
  212. (define-key global-map '(control /) 'undo)
  213. (define-key global-map "\C-_" 'undo)
  214. (define-key global-map "\M-!" 'shell-command)
  215. (define-key global-map "\M-|" 'shell-command-on-region)
  216.  
  217. (define-key global-map "\C-u" 'universal-argument)
  218. ;; Make Control-0 - Control-9 set the prefix argument, like Meta-0.
  219. (let ((i ?0))
  220.   (while (<= i ?9)
  221.     (define-key global-map (list 'meta i) 'digit-argument)
  222.     (define-key global-map (list 'control i) 'digit-argument)
  223.     (define-key global-map (list 'control 'meta i) 'digit-argument)
  224.     (setq i (1+ i))))
  225. (define-key global-map '(meta -) 'negative-argument)
  226. (define-key global-map '(control -) 'negative-argument)
  227. (define-key global-map '(control meta -) 'negative-argument)
  228.  
  229. (define-key global-map "\C-k" 'kill-line)
  230. (define-key global-map "\C-w" 'kill-region)
  231. (define-key global-map "\M-w" 'kill-ring-save)
  232. (define-key global-map "\M-\C-w" 'append-next-kill)
  233. (define-key global-map "\C-y" 'yank)
  234. (define-key global-map "\M-y" 'yank-pop)
  235.  
  236. ;; Old v18 binding
  237. ;(define-key global-map "\C-xa" 'append-to-buffer)
  238.  
  239. (define-key global-map "\C-@" 'set-mark-command)
  240. ;; Many people are used to typing C-SPC and getting C-@.
  241. (define-key global-map '(control ? ) 'set-mark-command)
  242. (define-key global-map "\C-x\C-x" 'exchange-point-and-mark)
  243. (define-key global-map "\C-x\C-@" 'pop-global-mark)
  244. (define-key global-map [(control x) (control ? )] 'pop-global-mark)
  245.  
  246. (define-key global-map "\C-n" 'next-line)
  247. (define-key global-map "\C-p" 'previous-line)
  248. ;(define-key global-map "\C-x\C-n" 'set-goal-column)
  249. ;; XEmacs:
  250. ;;; Many people have said they rarely use this feature, and often type
  251. ;;; it by accident.  Maybe it shouldn't even be on a key.
  252. ;;; Done.  -hniksic
  253. ;(put 'set-goal-column 'disabled t)
  254.  
  255. (define-key global-map [menu] 'execute-extended-command)
  256. (define-key global-map [find] 'search-forward)
  257.  
  258. (define-key global-map "\C-t" 'transpose-chars)
  259. (define-key global-map "\M-t" 'transpose-words)
  260. (define-key global-map "\M-\C-t" 'transpose-sexps)
  261. (define-key global-map "\C-x\C-t" 'transpose-lines)
  262.  
  263. (define-key global-map "\M-;" 'indent-for-comment)
  264. (define-key global-map "\M-j" 'indent-new-comment-line)
  265. (define-key global-map "\M-\C-j" 'indent-new-comment-line)
  266. (define-key global-map "\C-x;" 'set-comment-column)
  267. (define-key global-map "\C-xf" 'set-fill-column)
  268. (define-key global-map "\C-x$" 'set-selective-display)
  269.  
  270. (define-key global-map "\M-@" 'mark-word)
  271. (define-key global-map "\M-f" 'forward-word)
  272. (define-key global-map "\M-b" 'backward-word)
  273. (define-key global-map "\M-d" 'kill-word)
  274.  
  275. (define-key global-map "\M-<" 'beginning-of-buffer)
  276. (define-key global-map "\M->" 'end-of-buffer)
  277. (define-key global-map "\C-xh" 'mark-whole-buffer)
  278. (define-key global-map "\M-\\" 'delete-horizontal-space)
  279.  
  280. (define-key global-map "\M-\C-f" 'forward-sexp)
  281. (define-key global-map "\M-\C-b" 'backward-sexp)
  282. (define-key global-map "\M-\C-u" 'backward-up-list)
  283. (define-key global-map "\M-\C-@" 'mark-sexp)
  284. (define-key global-map "\M-\C-d" 'down-list)
  285. (define-key global-map "\M-\C-k" 'kill-sexp)
  286. (define-key global-map "\M-\C-n" 'forward-list)
  287. (define-key global-map "\M-\C-p" 'backward-list)
  288. (define-key global-map "\M-\C-a" 'beginning-of-defun)
  289. (define-key global-map "\M-\C-e" 'end-of-defun)
  290. (define-key global-map "\M-\C-h" 'mark-defun)
  291. (define-key global-map "\M-\(" 'insert-parentheses)
  292. (define-key global-map "\M-\)" 'move-past-close-and-reindent)
  293. (define-key global-map "\M-\t" 'lisp-complete-symbol)
  294.  
  295. (define-key global-map '(control meta backspace) 'backward-kill-sexp)
  296. (define-key global-map '(control meta delete) 'backward-or-forward-kill-sexp)
  297.  
  298.  
  299. (define-key global-map "\C-x/" 'point-to-register)
  300. (define-key global-map "\C-xj" 'jump-to-register)
  301. (define-key global-map "\C-xx" 'copy-to-register)
  302. (define-key global-map "\C-xg" 'insert-register)
  303. ;; Old v18 binding
  304. ;(define-key global-map "\C-xr" 'copy-rectangle-to-register)
  305.  
  306. ;; New FSF19 bindings: C-x r as a prefix for register commands
  307. (define-key global-map "\C-xr" (let ((map (make-sparse-keymap)))
  308.                                  (set-keymap-name map 'rectangle-prefix)
  309.                                  map))
  310. (define-key global-map "\C-xr\C-@" 'point-to-register)
  311. (define-key global-map "\C-xr " 'point-to-register)
  312. (define-key global-map "\C-xrj" 'jump-to-register)
  313. (define-key global-map "\C-xrs" 'copy-to-register)
  314. (define-key global-map "\C-xrx" 'copy-to-register)
  315. (define-key global-map "\C-xri" 'insert-register)
  316. (define-key global-map "\C-xrg" 'insert-register)
  317. (define-key global-map "\C-xrr" 'copy-rectangle-to-register)
  318. (define-key global-map "\C-xrc" 'clear-rectangle)
  319. (define-key global-map "\C-xrk" 'kill-rectangle)
  320. (define-key global-map "\C-xry" 'yank-rectangle)
  321. (define-key global-map "\C-xro" 'open-rectangle)
  322. (define-key global-map "\C-xrt" 'string-rectangle)
  323. (define-key global-map "\C-xrw" 'window-configuration-to-register)
  324. ;(define-key global-map "\C-xrf" 'frame-configuration-to-register)
  325.  
  326. (define-key global-map "\M-q" 'fill-paragraph-or-region)
  327. ;(define-key global-map "\M-q" 'fill-paragraph)
  328. ;(define-key global-map "\M-g" 'fill-region) ;now bound to goto-line
  329. (define-key global-map "\C-x." 'set-fill-prefix)
  330.  
  331. ; Using {} instead of [] is 1) FSF compatible and 2) allows function
  332. ; keys to work on ttys.  M-[ is the beginning of most the function key
  333. ; sequences.
  334. (define-key global-map "\M-{" 'backward-paragraph)
  335. (define-key global-map "\M-}" 'forward-paragraph)
  336. (define-key global-map "\M-h" 'mark-paragraph)
  337. (define-key global-map "\M-a" 'backward-sentence)
  338. (define-key global-map "\M-e" 'forward-sentence)
  339. (define-key global-map "\M-k" 'kill-sentence)
  340. ;;(define-key global-map "\C-x\177" 'backward-kill-sentence)
  341.  
  342. (define-key global-map "\C-x[" 'backward-page)
  343. (define-key global-map "\C-x]" 'forward-page)
  344. (define-key global-map "\C-x\C-p" 'mark-page)
  345. (define-key global-map "\C-xl" 'count-lines-page)
  346. (define-key global-map "\C-xnp" 'narrow-to-page)
  347. ;; Old v18 bindings
  348. ;(define-key global-map "\C-xp" 'narrow-to-page)
  349. (put 'narrow-to-page 'disabled t)
  350.  
  351. ;; Old v18 bindings
  352. ;(define-key global-map "\C-x\C-a" 'add-mode-abbrev)
  353. ;(define-key global-map "\C-x+" 'add-global-abbrev)
  354. ;(define-key global-map "\C-x\C-h" 'inverse-add-mode-abbrev)
  355. ;(define-key global-map "\C-x-" 'inverse-add-global-abbrev)
  356.  
  357. (define-key global-map "\M-'" 'abbrev-prefix-mark)
  358. (define-key global-map "\C-x'" 'expand-abbrev)
  359.  
  360. ;; New FSF19 bindings: C-x a as a prefix for abbrev commands
  361. (define-key global-map "\C-xal" 'add-mode-abbrev)
  362. (define-key global-map "\C-xa\C-a" 'add-mode-abbrev)
  363. (define-key global-map "\C-xag" 'add-global-abbrev)
  364. (define-key global-map "\C-xa+" 'add-mode-abbrev)
  365. (define-key global-map "\C-xaig" 'inverse-add-global-abbrev)
  366. (define-key global-map "\C-xail" 'inverse-add-mode-abbrev)
  367. (define-key global-map "\C-xa-" 'inverse-add-global-abbrev)
  368. (define-key global-map "\C-xae" 'expand-abbrev)
  369. (define-key global-map "\C-xa'" 'expand-abbrev)
  370.  
  371. (define-key global-map "\M-\C-l" 'switch-to-other-buffer)
  372.  
  373. ;; Default binding of "Backspace" is no longer the same as delete.
  374. ;; Default binding of "Control-h" is help.
  375. (define-key global-map 'backspace 'delete-backward-char)
  376. (define-key global-map '(meta backspace) 'backward-kill-word)
  377.  
  378. (define-key global-map "\M-\C-z" 'activate-region)
  379.  
  380. ;; FSFmacs macros.c
  381.  
  382. (define-key global-map "\C-xe" 'call-last-kbd-macro)
  383. (define-key global-map "\C-x\(" 'start-kbd-macro)
  384. (define-key global-map "\C-x\)" 'end-kbd-macro)
  385.  
  386. ;; FSFmacs macros.el
  387.  
  388. (define-key global-map "\C-xq" 'kbd-macro-query)
  389.  
  390.  
  391. ;; FSFmacs minibuffer.c
  392. ; see also minibuf.el
  393.  
  394. (define-key global-map "\M-\C-c" 'exit-recursive-edit)
  395. (define-key global-map "\C-]" 'abort-recursive-edit)
  396. (define-key global-map "\M-x" 'execute-extended-command)
  397.  
  398. ;; FSFmacs window.c
  399.  
  400. (define-key global-map "\C-x0" 'delete-window)
  401. (define-key global-map "\C-x1" 'delete-other-windows)
  402. (define-key global-map "\C-x2" 'split-window-vertically)
  403. (define-key global-map "\C-x3" 'split-window-horizontally)
  404. ;; Old XEmacs binding
  405. ;;(define-key global-map "\C-x5" 'split-window-horizontally)
  406. (define-key global-map "\C-xo" 'other-window)
  407. (define-key global-map "\C-x^" 'enlarge-window)
  408. (define-key global-map "\C-x<" 'scroll-left)
  409. (define-key global-map "\C-x>" 'scroll-right)
  410.  
  411. (define-key global-map "\C-v" 'scroll-up)
  412. (define-key global-map "\M-v" 'scroll-down)
  413. (define-key global-map "\M-\C-v" 'scroll-other-window)
  414. ; meta-shift-V, that is.
  415. (define-key global-map '(meta V) 'scroll-other-window-down)
  416.  
  417. (define-key global-map "\C-l" 'recenter)
  418. (define-key global-map "\M-r" 'move-to-window-line)
  419.  
  420. ;; FSFmacs window.el
  421.  
  422. (define-key global-map "\C-x6" 'window-configuration-to-register)
  423. ;(define-key global-map "\C-x7" 'jump-to-register);ie register-to-window-config
  424. (define-key global-map "\C-x}" 'enlarge-window-horizontally)
  425. (define-key global-map "\C-x{" 'shrink-window-horizontally)
  426. ;; New FSF19 bindings
  427. (define-key global-map "\C-x-" 'shrink-window-if-larger-than-buffer)
  428. (define-key global-map "\C-x+" 'balance-windows)
  429. (define-key ctl-x-4-map "0" 'kill-buffer-and-window)
  430.  
  431. ;;(define-key global-map "\C-g" 'keyboard-quit)
  432. (let ((ch (quit-char)))
  433.   (if (or (characterp ch) (integerp ch))
  434.       (setq ch (char-to-string ch)))
  435.   (define-key global-map ch 'keyboard-quit))
  436. (define-key global-map "\e\e\e" 'keyboard-escape-quit)
  437.  
  438.  
  439.  
  440.  
  441.  
  442.  
  443. (define-key global-map "\M-%" 'query-replace)
  444.  
  445.  
  446. ; autoloaded
  447. ;(define-key global-map "\C-x4a" 'add-change-log-entry-other-window)
  448.  
  449. ; autoloaded
  450. ;(define-key global-map "\C-x`" 'next-error)
  451.  
  452. ; autoloaded
  453. ;(define-key global-map "\M-/" 'dabbrev-expand)
  454.  
  455. ; autoloaded
  456. ;(define-key global-map "\C-xd" 'dired)
  457.  
  458. ; autoloaded
  459. ;(define-key global-map "\C-x4d" 'dired-other-window)
  460.  
  461. (define-key global-map "\M-$" 'ispell-word)
  462.  
  463. (define-key global-map "\C-xm" 'compose-mail)
  464. (define-key global-map "\C-x4m" 'compose-mail-other-window)
  465. (define-key global-map "\C-x5m" 'compose-mail-other-frame)
  466.  
  467. (define-key global-map "\M-." 'find-tag)
  468.  
  469. (define-key global-map "\C-x4." 'find-tag-other-window)
  470.  
  471. (define-key global-map "\M-," 'tags-loop-continue)
  472.  
  473.  
  474. (define-key global-map '(control <) 'mark-beginning-of-buffer)
  475. (define-key global-map '(control >) 'mark-end-of-buffer)
  476.  
  477. (define-key global-map "\C-x\C-e" 'eval-last-sexp) ;bogus!
  478.  
  479.  
  480. (define-key global-map "\M-g" 'goto-line)
  481.  
  482. ;; Keypad type things
  483.  
  484. ;; I removed all the fkey crap, because where-is is now smart enough
  485. ;; to show all bindings. --ben
  486.  
  487. ;;; These aren't bound to kbd macros like "\C-b" so that they have the
  488. ;; expected behavior even in, for example, vi-mode.
  489.  
  490. ;; We use here symbolic names, assuming that the corresponding keys will
  491. ;; generate these keysyms.  This is not true on Suns, but x-win-sun.el 
  492. ;; fixes that.  If it turns out that the semantics of these keys should
  493. ;; differ from server to server, this should be moved into server-specific
  494. ;; files, but these appear to be the standard Motif and PC bindings.
  495.  
  496. ;; movement by units
  497. (define-key global-map 'left        'backward-char)
  498. (define-key global-map 'up        'previous-line)
  499. (define-key global-map 'right        'forward-char)
  500. (define-key global-map 'down        'next-line)
  501.  
  502. ;; movement by pages
  503. (define-key global-map 'prior        'scroll-down)
  504. (define-key global-map 'next        'scroll-up)
  505.  
  506. ;; movement to the limits
  507. (define-key global-map 'home        'beginning-of-line)
  508. (define-key global-map 'end        'end-of-line)
  509.  
  510. ;;; Miscellaneous key bindings
  511. (define-key global-map 'again        'repeat-complex-command)
  512. (define-key global-map 'insert        'overwrite-mode)
  513.  
  514. ;;; These aren't bound to kbd macros like "\C-b" so that they have the
  515. ;; expected behavior even in, for example, vi-mode.
  516.  
  517. ;; We use here symbolic names, assuming that the corresponding keys will
  518. ;; generate these keysyms.  This is not true on Suns, but x-win-sun.el 
  519. ;; fixes that.  If it turns out that the semantics of these keys should
  520. ;; differ from server to server, this should be moved into server-specific
  521. ;; files, but these appear to be the standard Motif and PC bindings.
  522.  
  523. ;; potential R6isms
  524. (define-key global-map 'kp-left        'backward-char)
  525. (define-key global-map 'kp-up        'previous-line)
  526. (define-key global-map 'kp-right    'forward-char)
  527. (define-key global-map 'kp-down        'next-line)
  528.  
  529.  
  530. ;; movement by larger blocks
  531. (define-key global-map '(control left)    'backward-word)
  532. (define-key global-map '(control up)    #'(lambda ()
  533.                         (interactive "_")
  534.                         (forward-line -6)))
  535. (define-key global-map '(control right)    'forward-word)
  536. (define-key global-map '(control down)    #'(lambda ()
  537.                         (interactive "_")
  538.                         (forward-line 6)))
  539.  
  540. ;; context-sensitive movement
  541. (define-key global-map '(meta left)  'backward-sexp)
  542. (define-key global-map '(meta right) 'forward-sexp)
  543. (define-key global-map '(meta up)    'backward-paragraph)
  544. (define-key global-map '(meta down)  'forward-paragraph)
  545.  
  546. ;; movement by pages
  547. (define-key global-map '(control prior)    'scroll-right)
  548. (define-key global-map '(control next)    'scroll-left)
  549. ;; potential R6isms
  550. (define-key global-map 'kp-prior    'scroll-down)
  551. (define-key global-map 'kp-next        'scroll-up)
  552. (define-key global-map '(control kp-prior) 'scroll-right)
  553. (define-key global-map '(control kp-next) 'scroll-left)
  554.  
  555.  
  556. ;; movement to the limits
  557. (define-key global-map '(control home)    'beginning-of-buffer)
  558. (define-key global-map '(control end)    'end-of-buffer)
  559. (define-key global-map 'begin        'beginning-of-line)
  560. (define-key global-map '(control begin)    'beginning-of-buffer)
  561. ;; potential R6isms
  562. (define-key global-map 'kp-home        'beginning-of-line)
  563. (define-key global-map '(control kp-home) 'beginning-of-buffer)
  564. (define-key global-map 'kp-end        'end-of-line)
  565. (define-key global-map '(control kp-end) 'end-of-buffer)
  566.  
  567. ;; movement between windows
  568. (define-key global-map '(control tab)    'other-window)
  569. (define-key global-map '(control shift tab) 'backward-other-window)
  570.  
  571. ;; movement in other windows
  572. (define-key global-map '(meta next)    'scroll-other-window)
  573. (define-key global-map '(meta prior)    'scroll-other-window-down)
  574. (define-key global-map '(meta home)    'beginning-of-buffer-other-window)
  575. (define-key global-map '(meta end)    'end-of-buffer-other-window)
  576. ;; potential R6isms
  577. (define-key global-map '(meta kp-next)    'scroll-other-window)
  578. (define-key global-map '(meta kp-prior)    'scroll-other-window-down)
  579. (define-key global-map '(meta kp-home)    'beginning-of-buffer-other-window)
  580. (define-key global-map '(meta kp-end)    'end-of-buffer-other-window)
  581.  
  582. ;; potential R6isms
  583. (define-key global-map 'redo        'repeat-complex-command)
  584. (define-key global-map 'kp-insert    'overwrite-mode)
  585. (define-key global-map 'kp-delete    'backward-delete-char-untabify)
  586.  
  587. (define-key global-map 'kp-enter    [return]) ; do whatever RET does now
  588. (define-key global-map 'kp-tab        [tab])
  589.  
  590. (define-key global-map 'undo        'undo)
  591. (define-key global-map 'help        'help-for-help)
  592.  
  593. (define-key global-map 'kp-space    'self-insert-command)
  594. (define-key global-map 'kp-equal    'self-insert-command)
  595. (define-key global-map 'kp-multiply    'self-insert-command)
  596. (define-key global-map 'kp-add        'self-insert-command)
  597. (define-key global-map 'kp-separator    'self-insert-command)
  598. (define-key global-map 'kp-subtract    'self-insert-command)
  599. (define-key global-map 'kp-decimal    'self-insert-command)
  600. (define-key global-map 'kp-divide    'self-insert-command)
  601.  
  602. (define-key global-map 'kp-0        'self-insert-command)
  603. (define-key global-map 'kp-1        'self-insert-command)
  604. (define-key global-map 'kp-2        'self-insert-command)
  605. (define-key global-map 'kp-3        'self-insert-command)
  606. (define-key global-map 'kp-4        'self-insert-command)
  607. (define-key global-map 'kp-5        'self-insert-command)
  608. (define-key global-map 'kp-6        'self-insert-command)
  609. (define-key global-map 'kp-7        'self-insert-command)
  610. (define-key global-map 'kp-8        'self-insert-command)
  611. (define-key global-map 'kp-9        'self-insert-command)
  612.  
  613. (define-key global-map 'select        'function-key-error)
  614. (define-key global-map 'print        'function-key-error)
  615. (define-key global-map 'execute        'execute-extended-command)
  616. (define-key global-map 'clearline    'function-key-error)
  617. (define-key global-map 'insertline    'open-line)
  618. (define-key global-map 'deleteline    'kill-line)
  619. (define-key global-map 'insertchar    'function-key-error)
  620. (define-key global-map 'deletechar    'delete-char)
  621.  
  622. ;;; keydefs.el ends here
  623.